From: Boris Ostrovsky Date: Wed, 28 Sep 2016 13:22:03 +0000 (-0400) Subject: libxl/pvhv2: Include APIC page in MMIO hole for PVHv2 guests X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~283 X-Git-Url: https://dgit.raspbian.org/%22http:/www.example.com/cgi/%22https:/%22bookmarks:/%22man:///%22http:/www.example.com/cgi/%22https:/%22bookmarks:/%22man:/?a=commitdiff_plain;h=008eeb6be20cfa668989b6637f0bab0121052b5b;p=xen.git libxl/pvhv2: Include APIC page in MMIO hole for PVHv2 guests Signed-off-by: Boris Ostrovsky Acked-by: Wei Liu --- diff --git a/tools/libxl/Makefile b/tools/libxl/Makefile index a3c0af8c68..90427ff769 100644 --- a/tools/libxl/Makefile +++ b/tools/libxl/Makefile @@ -166,6 +166,8 @@ $(XL_OBJS) $(TEST_PROG_OBJS) _libxl.api-for-check: \ $(XL_OBJS): CFLAGS += $(CFLAGS_XL) $(XL_OBJS): CFLAGS += -include $(XEN_ROOT)/tools/config.h # libxl_json.h needs it. +libxl_dom.o: CFLAGS += -I$(XEN_ROOT)/tools # include libacpi/x86.h + SAVE_HELPER_OBJS = libxl_save_helper.o _libxl_save_msgs_helper.o $(SAVE_HELPER_OBJS): CFLAGS += $(CFLAGS_libxenctrl) $(CFLAGS_libxenevtchn) diff --git a/tools/libxl/libxl_arch.h b/tools/libxl/libxl_arch.h index 34a853c7b4..253a037378 100644 --- a/tools/libxl/libxl_arch.h +++ b/tools/libxl/libxl_arch.h @@ -62,4 +62,10 @@ int libxl__arch_domain_construct_memmap(libxl__gc *gc, uint32_t domid, struct xc_dom_image *dom); +#if defined(__i386__) || defined(__x86_64__) + +#define LAPIC_BASE_ADDRESS 0xfee00000 + +#endif + #endif diff --git a/tools/libxl/libxl_dom.c b/tools/libxl/libxl_dom.c index 7974302001..29246298ba 100644 --- a/tools/libxl/libxl_dom.c +++ b/tools/libxl/libxl_dom.c @@ -1077,10 +1077,21 @@ int libxl__build_hvm(libxl__gc *gc, uint32_t domid, dom->target_pages = mem_size >> XC_PAGE_SHIFT; if (dom->mmio_size == 0 && device_model) dom->mmio_size = HVM_BELOW_4G_MMIO_LENGTH; - else if (dom->mmio_size == 0 && !device_model) - dom->mmio_size = GB(4) - - ((X86_HVM_END_SPECIAL_REGION - X86_HVM_NR_SPECIAL_PAGES) - << XC_PAGE_SHIFT); + else if (dom->mmio_size == 0 && !device_model) { +#if defined(__i386__) || defined(__x86_64__) + if (libxl_defbool_val(info->u.hvm.apic)) { + /* Make sure LAPIC_BASE_ADDRESS is below special pages */ + assert(((((X86_HVM_END_SPECIAL_REGION - X86_HVM_NR_SPECIAL_PAGES) + << XC_PAGE_SHIFT) - LAPIC_BASE_ADDRESS)) >= XC_PAGE_SIZE); + dom->mmio_size = GB(4) - LAPIC_BASE_ADDRESS; + } else + dom->mmio_size = GB(4) - + ((X86_HVM_END_SPECIAL_REGION - X86_HVM_NR_SPECIAL_PAGES) + << XC_PAGE_SHIFT); +#else + assert(1); +#endif + } lowmem_end = mem_size; highmem_end = 0; mmio_start = (1ull << 32) - dom->mmio_size;